草庐IT

Java CMS GC 行为

全部标签

c++ - 为什么我下面的第二个片段显示未定义的行为?

clang和g++似乎都符合C++标准中段落[expr.const]/5的最新版本。以下代码段为两个编译器打印11。参见liveexample:#includevoidf(void){staticintn=11;staticint*temp=&n;staticconstexprint*&&r=std::move(temp);std::cout根据我对这一段的理解,两个编译器都应该为下面的代码打印2016。但他们没有。因此,我必须得出结论,该代码显示了未定义的行为,因为clang打印了一个任意数字,而g++打印了0。我想知道为什么是UB,例如,考虑到标准的N4527草案?Liveexam

c++ - std::vector 保留后 operator[] 上 msvc 和 gcc 之间的行为差​​异,哪个是对的?

Thissnippetofcode使用msvc(越界错误)惨遭失败,但似乎在gcc和clang上都能正常工作。什么是正确的行为?#include#includeintmain(){std::vectorv;v.reserve(10);for(inti=0;i 最佳答案 行为未定义。reserve只保留内存,不影响容器的大小。也许您想使用resize?std::vectorv;v.resize(10);for(inti=0;i虽然在这种情况下你可以写std::vectorv(10);for(inti=0;i或者,您可以将reserve

c++ - 在初始化列表中调用私有(private)函数的情况下,它是未定义的行为吗?

考虑以下代码:structCalc{Calc(constArg1&arg1,constArg2&arg2,/**/constArgN&argn):arg1(arg1),arg2(arg2),/**/argn(argn),coef1(get_coef1()),coef2(get_coef2()){}intCalc1();intCalc2();intCalc3();private:constArg1&arg1;constArg2&arg2;//...constArgN&argn;constintcoef1;//Iwanttouseconstbecauseconstintcoef2;//no

c++ - 为什么这是未定义的行为?

为什么下面给定的表达式会调用未定义的行为?inti=5;i=(i,i++,i)+1我的问题是受Als的影响questionhere 最佳答案 它不是未定义的。在这里回答C,Sequencepointsandpartialorder我认为这同样适用于C++(这是我在看到该链接之前的回复):逗号运算符引入了一个序列点(并在某种程度上限制了表达式必须计算的顺序-先左后右),因此:i的两个修改由序列点(第二个逗号)分隔。i++中i的修改通过序列点与其他所有内容分开。=对i的修改与表达式中最后一次出现的i不分开,但这没关系,因为我们被允许访问

c++ - 我怎样才能让 g++ 模仿 MSVC++ 的模板实例化行为?

我正在尝试将我自己的库从VisualStudio移植到GNU/Linux上的g++,但我遇到了一些模板编译问题。事实上,在VisualC++中,只有在代码中明确使用模板时才会生成模板,而g++似乎(从我的错误来看)在模板首次使用之前评估模板的内容。这会导致以下错误:error:incompletetype‘X’usedinnestednamespecifier...因为我在模板代码之后而不是之前包含了一些类。由于交叉使用冲突,我这样做。总而言之,VisualC++似乎不会尝试在使用时解析模板的内容,而g++会尽快解析。classMyClass;templatevoidfunc(MyCl

c++ - std::map of boost::mutex 具有奇怪的行为

我有这个代码://////DefaultNamespaces///usingnamespacestd;typedefmapt_map_shared_mutex;intmain(intargc,char**argv){t_map_shared_mutexlist_lock;boost::shared_mutexglobal_lock;stringi="ABC";boost::unique_lockl_lock(global_lock);boost::unique_locklock(list_lock[i]);//DoSomethingwiththatlocklock.unlock();l

c++ - 从 STDIN 读取 int 时的奇怪行为

假设我们有一个向用户展示一些选项的菜单:Welcome:1)Dosomething2)Dosomethingelse3)Dosomethingcool4)Quit用户可以按1-4,然后按回车键。该程序执行此操作,然后将菜单呈现给用户。无效的选项应该再次显示菜单。我有以下main()方法:intmain(){while(true)switch(menu()){case1:doSomething();break;case2:doSomethingElse();break;case3:doSomethingCool();break;case4:return0;default:continue

c++ - 字符串类中 size() 和 at() 的不正确行为

我有这个代码:stringtest("żaba");cout输出很奇怪:Word:żabaLength:5Letter:�如您所见,长度应为4,字母:“ż”。如何更正此代码以使其正常工作? 最佳答案 你的问题没有提到编码,所以我要在黑暗中刺探一下,说这就是原因。第一步:阅读TheAbsoluteMinimumEverySoftwareDeveloperAbsolutely,PositivelyMustKnowAboutUnicodeandCharacterSets(NoExcuses!).在那之后,应该清楚“裸字符串”这样的东西并不

c++ - XOR 交换算法中运算符的未定义行为?

voidswap(int*a,int*b){if(a!=b)*a^=*b^=*a^=*b;}因为上面的*a^=*b^=*a^=*b只是*a=*a^(*b=*b^(*a=*a^*b)),可以(例如)在第三个*a之前对第二个*a进行求值(对于XOR)修改(由=)?用C99/C11/C++98/C++11写有关系吗? 最佳答案 C++11标准说:5.17/1:Theassignmentoperator(=)andthecompoundassignmentoperatorsallgroupright-to-left.(...)theassi

c++ - 在复制初始化中是否返回对本地对象未定义行为的引用?

考虑以下代码:structfoo{foo(fooconst&)=default;//Tomakesureitexists};foo&get_local_foo_reference(){foomy_local_foo;returnmy_local_foo;//Returnareferencetoalocalvariable}intmain(){foomy_foo=get_local_foo_reference();}现在每个人都会同意返回对局部变量的引用是不好的并且会导致未定义的行为。但在copyinitialization的情况下(如上代码所示)参数是一个常量左值引用,所以它应该是一个